GtkStateFlags previous_state);
static void _gtk_window_set_is_active (GtkWindow *window,
gboolean is_active);
+static void gtk_window_present_toplevel (GtkWindow *window);
+static void gtk_window_update_toplevel (GtkWindow *window);
+static GdkToplevelLayout * gtk_window_compute_layout (GtkWindow *window,
+ int min_width,
+ int min_height);
static GListStore *toplevel_list = NULL;
static guint window_signals[LAST_SIGNAL] = { 0 };
_gtk_window_toggle_maximized (window);
}
else if (g_str_equal (action, "lower"))
- gdk_surface_lower (priv->surface);
+ gdk_toplevel_lower (GDK_TOPLEVEL (priv->surface));
else if (g_str_equal (action, "minimize"))
- gdk_surface_minimize (priv->surface);
+ gdk_toplevel_minimize (GDK_TOPLEVEL (priv->surface));
else if (g_str_equal (action, "menu"))
gtk_window_do_popup (window, (GdkEventButton*) event);
else
event_widget = gtk_get_event_widget ((GdkEvent *) event);
if (region == GTK_WINDOW_REGION_TITLE)
- gdk_surface_raise (priv->surface);
+ gtk_window_update_toplevel (window);
switch (region)
{
priv->title = new_title;
if (_gtk_widget_get_realized (GTK_WIDGET (window)))
- gdk_surface_set_title (priv->surface, new_title != NULL ? new_title : "");
+ gdk_toplevel_set_title (GDK_TOPLEVEL (priv->surface), new_title != NULL ? new_title : "");
if (update_titlebar && GTK_IS_HEADER_BAR (priv->title_box))
gtk_header_bar_set_title (GTK_HEADER_BAR (priv->title_box), new_title != NULL ? new_title : "");
gtk_window_present_with_time (window, timestamp);
else
{
- gdk_surface_set_startup_id (priv->surface, priv->startup_id);
+ gdk_toplevel_set_startup_id (GDK_TOPLEVEL (priv->surface), priv->startup_id);
/* If window is mapped, terminate the startup-notification too */
if (_gtk_widget_get_mapped (widget) && !disable_startup_notification)
priv->modal = modal;
widget = GTK_WIDGET (window);
- /* adjust desired modality state */
if (_gtk_widget_get_realized (widget))
- gdk_surface_set_modal_hint (priv->surface, priv->modal);
+ gdk_toplevel_set_modal (GDK_TOPLEVEL (priv->surface), modal);
if (gtk_widget_get_visible (widget))
{
GtkWindowPrivate *priv = gtk_window_get_instance_private (GTK_WINDOW (window));
GtkWindowPrivate *parent_priv = gtk_window_get_instance_private (GTK_WINDOW (parent));
if (_gtk_widget_get_realized (window))
- gdk_surface_set_transient_for (priv->surface, parent_priv->surface);
+ gdk_toplevel_set_transient_for (GDK_TOPLEVEL (priv->surface), parent_priv->surface);
}
static void
{
GtkWindowPrivate *priv = gtk_window_get_instance_private (GTK_WINDOW (window));
if (_gtk_widget_get_realized (window))
- gdk_surface_set_transient_for (priv->surface, NULL);
+ gdk_toplevel_set_transient_for (GDK_TOPLEVEL (priv->surface), NULL);
}
static void
}
static void
-gtk_window_unset_transient_for (GtkWindow *window)
+gtk_window_unset_transient_for (GtkWindow *window)
{
GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
{
priv->accept_focus = setting;
if (_gtk_widget_get_realized (GTK_WIDGET (window)))
- gdk_surface_set_accept_focus (priv->surface, priv->accept_focus);
+ gdk_toplevel_set_accept_focus (GDK_TOPLEVEL (priv->surface), priv->accept_focus);
g_object_notify_by_pspec (G_OBJECT (window), window_props[PROP_ACCEPT_FOCUS]);
}
}
{
priv->focus_on_map = setting;
if (_gtk_widget_get_realized (GTK_WIDGET (window)))
- gdk_surface_set_focus_on_map (priv->surface, priv->focus_on_map);
+ gdk_toplevel_set_focus_on_map (GDK_TOPLEVEL (priv->surface), priv->focus_on_map);
g_object_notify_by_pspec (G_OBJECT (window), window_props[PROP_FOCUS_ON_MAP]);
}
}
priv->decorated = setting;
if (priv->surface)
- {
- if (priv->decorated)
- {
- if (priv->client_decorated)
- gdk_surface_set_decorations (priv->surface, 0);
- else
- gdk_surface_set_decorations (priv->surface, GDK_DECOR_ALL);
- }
- else
- gdk_surface_set_decorations (priv->surface, 0);
- }
+ gdk_toplevel_set_decorated (GDK_TOPLEVEL (priv->surface), priv->decorated && !priv->client_decorated);
update_window_buttons (window);
gtk_widget_queue_resize (GTK_WIDGET (window));
priv->deletable = setting;
if (priv->surface)
- {
- if (priv->deletable)
- gdk_surface_set_functions (priv->surface, GDK_FUNC_ALL);
- else
- gdk_surface_set_functions (priv->surface,
- GDK_FUNC_ALL | GDK_FUNC_CLOSE);
- }
+ gdk_toplevel_set_deletable (GDK_TOPLEVEL (priv->surface), priv->deletable);
update_window_buttons (window);
info->realized = TRUE;
- gdk_surface_set_icon_list (priv->surface, icon_list);
+ gdk_toplevel_set_icon_list (GDK_TOPLEVEL (priv->surface), icon_list);
if (GTK_IS_HEADER_BAR (priv->title_box))
_gtk_header_bar_update_window_icon (GTK_HEADER_BAR (priv->title_box), window);
gtk_grab_remove (widget);
}
+static GdkToplevelLayout *
+gtk_window_compute_layout (GtkWindow *window,
+ int min_width,
+ int min_height)
+{
+ GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
+ GdkToplevelLayout *layout;
+
+ layout = gdk_toplevel_layout_new (min_width, min_height);
+
+ gdk_toplevel_layout_set_resizable (layout, priv->resizable);
+ gdk_toplevel_layout_set_maximized (layout, priv->maximize_initially);
+ gdk_toplevel_layout_set_fullscreen (layout,
+ priv->fullscreen_initially,
+ priv->initial_fullscreen_monitor);
+
+ return layout;
+}
+
+static void
+gtk_window_present_toplevel (GtkWindow *window)
+{
+ GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
+ GdkToplevelLayout *layout;
+ GdkRectangle request;
+ GdkGeometry geometry;
+ GdkSurfaceHints flags;
+
+ gtk_window_compute_configure_request (window, &request,
+ &geometry, &flags);
+
+ if (!(flags & GDK_HINT_MIN_SIZE))
+ geometry.min_width = geometry.min_height = 1;
+
+ layout = gtk_window_compute_layout (window, geometry.min_width, geometry.min_height);
+
+ gdk_toplevel_present (GDK_TOPLEVEL (priv->surface),
+ request.width,
+ request.height,
+ layout);
+ gdk_toplevel_layout_unref (layout);
+}
+
+static void
+gtk_window_update_toplevel (GtkWindow *window)
+{
+ GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
+
+
+ if (priv->surface && gdk_surface_get_mapped (priv->surface))
+ {
+ GdkToplevelLayout *layout;
+
+ layout = gtk_window_compute_layout (window, 1, 1);
+ gdk_toplevel_present (GDK_TOPLEVEL (priv->surface),
+ gdk_surface_get_width (priv->surface),
+ gdk_surface_get_height (priv->surface),
+ layout);
+ gdk_toplevel_layout_unref (layout);
+ }
+}
+
static void
gtk_window_map (GtkWidget *widget)
{
GtkWidget *child;
GtkWindow *window = GTK_WINDOW (widget);
GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
- GdkSurface *surface;
+ GdkToplevelLayout *layout;
GTK_WIDGET_CLASS (gtk_window_parent_class)->map (widget);
gtk_widget_get_child_visible (priv->title_box))
gtk_widget_map (priv->title_box);
- surface = priv->surface;
-
- if (priv->maximize_initially)
- gdk_surface_maximize (surface);
- else
- gdk_surface_unmaximize (surface);
-
- if (priv->stick_initially)
- gdk_surface_stick (surface);
- else
- gdk_surface_unstick (surface);
+ gdk_toplevel_set_sticky (GDK_TOPLEVEL (priv->surface), priv->stick_initially);
+ gdk_toplevel_set_keep_above (GDK_TOPLEVEL (priv->surface), priv->above_initially);
+ gdk_toplevel_set_keep_below (GDK_TOPLEVEL (priv->surface), priv->below_initially);
+
+ layout = gdk_toplevel_layout_new (1, 1);
+ gdk_toplevel_layout_set_resizable (layout, priv->resizable);
+ gdk_toplevel_layout_set_maximized (layout, priv->maximize_initially);
+ gdk_toplevel_layout_set_fullscreen (layout,
+ priv->fullscreen_initially,
+ priv->initial_fullscreen_monitor);
+ gdk_toplevel_present (GDK_TOPLEVEL (priv->surface),
+ gdk_surface_get_width (priv->surface),
+ gdk_surface_get_height (priv->surface),
+ layout);
+ gdk_toplevel_layout_unref (layout);
if (priv->minimize_initially)
- gdk_surface_minimize (surface);
- else
- gdk_surface_unminimize (surface);
-
- if (priv->fullscreen_initially)
- {
- if (priv->initial_fullscreen_monitor)
- gdk_surface_fullscreen_on_monitor (surface, priv->initial_fullscreen_monitor);
- else
- gdk_surface_fullscreen (surface);
- }
- else
- gdk_surface_unfullscreen (surface);
-
- gdk_surface_set_keep_above (surface, priv->above_initially);
-
- gdk_surface_set_keep_below (surface, priv->below_initially);
+ gdk_toplevel_minimize (GDK_TOPLEVEL (priv->surface));
gtk_window_set_theme_variant (window);
/* No longer use the default settings */
priv->need_default_size = FALSE;
- gdk_surface_show (surface);
-
if (!disable_startup_notification)
{
/* Do we have a custom startup-notification id? */
_gtk_widget_get_realized (GTK_WIDGET (priv->transient_parent)))
{
GtkWindowPrivate *parent_priv = gtk_window_get_instance_private (priv->transient_parent);
- gdk_surface_set_transient_for (surface, parent_priv->surface);
+ gdk_toplevel_set_transient_for (GDK_TOPLEVEL (surface), parent_priv->surface);
}
- gdk_surface_set_type_hint (surface, priv->type_hint);
-
if (priv->title)
- gdk_surface_set_title (surface, priv->title);
+ gdk_toplevel_set_title (GDK_TOPLEVEL (surface), priv->title);
- if (!priv->decorated || priv->client_decorated)
- gdk_surface_set_decorations (surface, 0);
+ gdk_toplevel_set_decorated (GDK_TOPLEVEL (surface), priv->decorated && !priv->client_decorated);
+ gdk_toplevel_set_deletable (GDK_TOPLEVEL (surface), priv->deletable);
#ifdef GDK_WINDOWING_WAYLAND
if (priv->client_decorated && GDK_IS_WAYLAND_SURFACE (surface))
gdk_wayland_surface_announce_csd (surface);
#endif
- if (!priv->deletable)
- gdk_surface_set_functions (surface, GDK_FUNC_ALL | GDK_FUNC_CLOSE);
-
- if (gtk_window_get_accept_focus (window))
- gdk_surface_set_accept_focus (surface, TRUE);
- else
- gdk_surface_set_accept_focus (surface, FALSE);
-
- if (gtk_window_get_focus_on_map (window))
- gdk_surface_set_focus_on_map (surface, TRUE);
- else
- gdk_surface_set_focus_on_map (surface, FALSE);
-
- if (priv->modal)
- gdk_surface_set_modal_hint (surface, TRUE);
- else
- gdk_surface_set_modal_hint (surface, FALSE);
+ gdk_toplevel_set_accept_focus (GDK_TOPLEVEL (surface),
+ gtk_window_get_accept_focus (window));
+ gdk_toplevel_set_focus_on_map (GDK_TOPLEVEL (surface),
+ gtk_window_get_focus_on_map (window));
+ gdk_toplevel_set_modal (GDK_TOPLEVEL (surface), priv->modal);
if (priv->startup_id)
{
}
#endif
if (!startup_id_is_fake (priv->startup_id))
- gdk_surface_set_startup_id (surface, priv->startup_id);
+ gdk_toplevel_set_startup_id (GDK_TOPLEVEL (surface), priv->startup_id);
}
#ifdef GDK_WINDOWING_X11
maximize_window_clicked (GtkModelButton *button,
gpointer user_data)
{
- GtkWindow *window = GTK_WINDOW (user_data);
- GdkSurfaceState state;
-
- state = gtk_window_get_state (window);
-
- if (state & GDK_SURFACE_STATE_MINIMIZED)
- gtk_window_unminimize (window);
-
- gtk_window_maximize (window);
+ gtk_window_maximize (GTK_WINDOW (user_data));
}
static void
{
GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
- if (!gdk_surface_show_window_menu (priv->surface, (GdkEvent *) event))
+ if (!gdk_toplevel_show_window_menu (GDK_TOPLEVEL (priv->surface), (GdkEvent *) event))
gtk_window_do_popup_fallback (window, event);
}
gboolean hints_changed; /* do we need to send these again */
GtkWindowLastGeometryInfo saved_last_info;
int current_width, current_height;
+ GdkToplevelLayout *layout;
widget = GTK_WIDGET (window);
hints_changed = TRUE;
}
- /* Set hints if necessary
- */
- if (hints_changed)
- gdk_surface_set_geometry_hints (priv->surface,
- &new_geometry,
- new_flags);
-
current_width = gdk_surface_get_width (priv->surface);
current_height = gdk_surface_get_height (priv->surface);
if (configure_request_pos_changed)
g_warning ("configure request position changed. This should not happen. Ignoring the position");
- gdk_surface_resize (priv->surface,
- new_request.width, new_request.height);
+ layout = gtk_window_compute_layout (window, 1, 1);
+ gdk_toplevel_present (GDK_TOPLEVEL (priv->surface),
+ new_request.width, new_request.height,
+ layout);
+ gdk_toplevel_layout_unref (layout);
}
else
{
g_assert (surface != NULL);
- gdk_surface_show (surface);
+ gtk_window_present_toplevel (window);
/* Translate a timestamp of GDK_CURRENT_TIME appropriately */
if (timestamp == GDK_CURRENT_TIME)
timestamp = gtk_get_current_event_time ();
}
- gdk_surface_focus (surface, timestamp);
+ gdk_toplevel_focus (GDK_TOPLEVEL (surface), timestamp);
}
else
{
priv->minimize_initially = TRUE;
if (priv->surface)
- gdk_surface_minimize (priv->surface);
+ gdk_toplevel_minimize (GDK_TOPLEVEL (priv->surface));
}
/**
priv->minimize_initially = FALSE;
- if (priv->surface)
- gdk_surface_unminimize (priv->surface);
+ gtk_window_update_toplevel (window);
}
/**
priv->stick_initially = TRUE;
if (priv->surface)
- gdk_surface_stick (priv->surface);
+ gdk_toplevel_set_sticky (GDK_TOPLEVEL (priv->surface), TRUE);
}
/**
priv->stick_initially = FALSE;
if (priv->surface)
- gdk_surface_unstick (priv->surface);
+ gdk_toplevel_set_sticky (GDK_TOPLEVEL (priv->surface), FALSE);
}
/**
priv->maximize_initially = TRUE;
- if (priv->surface)
- gdk_surface_maximize (priv->surface);
+ gtk_window_update_toplevel (window);
}
/**
priv->maximize_initially = FALSE;
- if (priv->surface)
- gdk_surface_unmaximize (priv->surface);
+ gtk_window_update_toplevel (window);
}
/**
priv->fullscreen_initially = TRUE;
- if (priv->surface)
- gdk_surface_fullscreen (priv->surface);
+ gtk_window_update_toplevel (window);
}
static void
priv->fullscreen_initially = TRUE;
- if (priv->surface)
- gdk_surface_fullscreen_on_monitor (priv->surface, monitor);
+ gtk_window_update_toplevel (window);
}
/**
unset_fullscreen_monitor (window);
priv->fullscreen_initially = FALSE;
- if (priv->surface)
- gdk_surface_unfullscreen (priv->surface);
+ gtk_window_update_toplevel (window);
}
/**
priv->below_initially &= !setting;
if (priv->surface)
- gdk_surface_set_keep_above (priv->surface, setting);
+ gdk_toplevel_set_keep_above (GDK_TOPLEVEL (priv->surface), setting);
}
/**
priv->above_initially &= !setting;
if (priv->surface)
- gdk_surface_set_keep_below (priv->surface, setting);
+ gdk_toplevel_set_keep_below (GDK_TOPLEVEL (priv->surface), setting);
}
/**